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@ To provide an external storage system using a 
semiconductor menfK>ry in which the data read- 
ing and writing t>etween the host CPU can be 
processed faster than the conventional mag- 
netic disk, and only a particular sector is not 
frequently written and erased so that the whole 
memory is effectively used over a long period of 
time, an address control scheme is introduced 
In which flexibility is given to the address rela- 
tk)n between the host CPU and the external 
storage and the physical address of the semi- 
conductor memory is not one-sidedly deter- 
mined by the logical address possessed by the 
command of the host CPU. 
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The present invention relates to computer menv 
ory devices using electricaliy erasable nonvotatile 
memory, known as flash EEPROM or flash memory 
and, more particularly, to a method for controlling 
such a memory for use in e.g. semiconductor external 
storage systems which can replace the nnagnetic disk 
In a conventional computer system. 

As portable personal computers such as note- 
book type ones have spread, the requirement for 
small-sized, lightweight and low power consumption 
computer systems has Increased. External storage 
using semiconductor memory has a low power con- 
sumption and can operate at a high speed because it 
does not use a ntechanical drive system such as the 
magnetic disk. In addition, it consists of small memory 
modules, and thus it is small-sized, lightweight, and 
has a large degree of freedom with respect to shape 
as compared with the magnetic disk, and is also easOy 
made In the form of a card. 

However, the conventional semiconductor menv 
ory has many problems with respect to such points as 
capacity and battery backup. If SRAM Is used as the 
memory, the cost is high and the capacity becomes 
small though the backup time by a battery becomes 
long. For DRAM which Is excellent in cost and capaci- 
ty, the standby power consumption Is large and the 
backup time is limited to one week or so. There is also 
a danger of data loss due to a problem In the battery 
system. EEPROM is costly though it requires no bat- 
tery. 

A block erase type flash memory has been devel- 
oped as a memory to solve these problems. Its menri- 
ory element consists of one transistor as DRAM, and 
It can be provided with high density and It Is expected 
to have a bit cost equivalent to or less than DRAM (low 
cost, large capacity) depending on the future market 
The memory element is nonvolatile and requires no 
battery backup. The outline of such flash memory Is 
introduced by Richard D. Pashley et al. In "Flash 
memories: the best of two worlds", IEEE SPEC- 
TRUM, Dec. 1989, pp. 30-33. Also, a similar flash 
memory Is disclosed in Japanese Published Unexa- 
mined Patent Application No. 2-10598. 

However, the flash memory has limitations which 
SRAM and DRAM do not have. Firet, the 
erase/program cycles have an upper limit of the order 
of 100,000. In addition, the programming of memory 
bits Is a one-way process and change is allowed only 
from 0 to 1 or 1 to 0. For change in the opposite direc- 
tion, it is necessary to set the whole memory block to 
0 or 1 by block erasure. Erasing usually takes several 
tens of milliseconds, and block erasure requires spe- 
cial procedures such as verify which takes a further 
several seconds. 

If a semiconductor memory consisting of such 
flash memory is connected to the bus of a host conv 
puter as an alternative to the traditional magnetic disk, 
a specific sector is very often written by the host com- 



puter and reaches the upper limit of the 
erase/program cycles considerably earlier than other 
sectora. Further, the sector writing takes a lot of time. 
The reason for this is that, to modify several bytes in 

5 . the sector, all the data within the memory block includ- 
ing the sector are temporarily saved In the memory 
space of the host computer, and new data is written 
back to empty sectore after erasing of the memory 
block. It takes several seconds to write a sector in a 

10 semiconductor memory having a capacity of 1 M bits 
or more. In addition, a special program is required to 
connect a semiconductor memory to the bus of the 
host computer. 

To solve these problems, the development of a 

15 sector erase type flash memory Is needed. For in- 
stance. 27F010 from SEEQ TECHNOLOGY COR- 
PORATION (1024K flash EPROM) allows not only the 
chip erasure which erases all the bits of the memory 
chip (change to logical one) but also the sector era- 

20 sure which erases only a specific sector. In this 
scheme, the saving or writing back of sectors other 
than those to be erased can be avoided. However, it 
takes on the order of several tens of milliseconds be- 
cause the erasing of old sectors Is done along with the 

25 writing of sectora, and thus the obtained performance 
is equivalent to or less than the magnetic disk. In ad- 
dition, the problem Is not soh^ed that a particular sec- 
tor is written very often by the host computer and 
reaches the allowed erase/program cycles somewhat 

30 earlier than other sectora,' and thus the sectora cannot 
effectively be used as the whole flash memory. Fur- 
ther, the sector erase type has a chip structure which 
Is nK>re complicated than the block erase type, and 
that there are also problems with respect to cost and 

35 erase/program cycles. 

Many of these problems are considered to be due 
to the control scheme in which the block and sector 
addresses of the external storage are controlled by 
the host computer, that Is, the physical address of the 

40 external storage is determined by the logical address 
possessed by the command of the host computer. 

This Invention provides a method for controlting a 
storage system comprising a semiconductor memory 
of a flash memory type, the memory comprising a 

45 plurality of menwry blocks each including at least one 
sector, and a control device for controlling said mem- 
ory blocks, said storage system being connected to a 
host processor through a bus for transferring data and 
a command; the method comprising selecting a menv 

60 ory block for which data is to be written or erased on 
the basis of a memory managing table which has re- 
corded therein the number of times each memory 
block was erased and the statuses of each memory 
block and each sector; converting the togical address 

55 included In said command of saki host processor to a 
physical address indicating the sector in a particular 
memory block by reference to an address converaion 
table; responding to said command to perform a proc- 
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ess of data writing or reading to the corresponding 
sector or memory block erasure, sequentially record- 
ing or updating in said memory managing table the 
status changes of each sector and memory blocic re- 
sulting from the processes in said block managing s 
means, and storing or updating in the address conver- 
sion table the relationships between the physical ad- 
dress and the logical addresses of the memory block ^ 
and sector on which said processes were performed. 

Advantageous features of embodiments of the in- io 
vention are set out in the attached dependent daims. 
The present Invention enables the provision of an ex- 
ternal storage system using a semiconductor mem- 
ory which can process the data reading and writing 
between the host computer at a speed higher than the is 
conventional magnetic disk. The whole semiconduc- 
tor memory is effectively used for a long period of time 
without firequently writing and erasing only a particular 
sector In the semiconductor memory. The semicon- 
ductor external storage system is compatible with a 20 
conventional magnetic disk when it is connected to a 
computer system. Files can easily be restored even If 
the power is disconnected in a writing. 

This is achieved by providing flexibility In the ad- 
dress relation between the host computer and the ex- 25 
ternal storage, and by introducing an address control 
scheme In which the physical address of the external 
storage is not one-sidedly decided on by the logical 
address possessed by the command of the host conv 
putisr. On the external storage side, a memory block 30 
or sector fbr writing or copying is always prepared for 
the command processing of the host, and the corre- 
spondence relationship of the physical address of the 
selected memory block or sector with the command 
of the host computer is recorded and held In an ad- 35 
dress conversion table. The status of the memory 
block and sector is recorded and managed In the re- 
spective managing tables. 

On the external storage side, an optimun) mem- 
ory block or sector can be selected In consideration 40 
of the processing speed of the host computer and the 
utilization efficiency of the semiconductor memory. In 
addition, the processing speed of the host computer 
can be increased without waiting for the command of 
the host, or executing the command processing in 4S 
parallel with ttie command of the host That is. mem- 
ory blocks In which data can be written or erased are 
prepared beforehand on the basis of the record in the 
memory managing means, thereby occasioning a fast 
processing in response to the command of the host so 
processor. Moreover, since the memory blocks and 
sectors of the semiconductor memory can be totally 
managed and the physical address can freely be se- 
lected in consideration of the utilization efficiency, the 
unnecessaryfrequent erasure of a particular memory 55 
block in the semiconductor memory is eliminated and 
the whole memory Is effectively used over a long per- 
iod of time. Since the host computer can give a conrv 



mand to the external storage without considering the 
physical address and receive the result of the proc- 
ess, compatibility with the tradittonal magnetic disk 
can be maintained. Also, no rewriting of data directiy 
connected with the command address of the host 
processor Is performed, and Uius files can easily be 
recovered. 

in accordance with one emt)odiment of the pres- 
ent invention, a semiconductor external storage sys- 
tem comprises: a semiconductor memory consisting 
of a flash memory and comprised of a plurality of 
memory blocks each including at least one sector, an 
address convereion table, block managing means, 
and a comnuind processing section; the address con- 
version table is used to record the correspondence re- 
lationship of the physical address of a sector or mem- 
ory block with the command of the host processor, 
and the block mananging means records the number 
of times each memory block was erased and the sta- 
tus of each memory block and sector, the command 
processing section selects a memory block in which 
data writing or eriasing Is performed on the basis of 
the record of the block managing means, executes a 
process of data writing, reading or erasing to the 
memory block or sector that has the physical address 
obtained from the address conversion table in re- 
sponse to the command, sequentially records and up- 
dates the status change of each sector or nrtemory 
block in the block managing means, records and up- 
dates the correspondence relationship of the physical 
address of the sector or memory block with the logical 
address firom ttie host processor in the address con- 
version table, and selects a menfK)ry block In which a 
data writing or erasing is to be executed next on the 
basis of the record of the block managing means. 

Embodiments of ttie invention will now be descri- 
bed, by way of example only, with reference to the ac- 
companying drawing, wherein: 

Figure 1 shows an example of the computer sys- 
tem In whteh the semiconductor external storage 
system of the present invention is Incorporated; 
Figure 2 shows the detail of the functkins of an 
embodiment of the semiconductor external stor- 
age system of the present invention; 
Figure 3 shows the details of the construction 
used for implementing the functions of the semi- 
conductor external storage system of Figure 2; 
Figure 4 shows an example of the sector con- 
struction of a memory block; 
Figure 5 shows an example of ttie construction of 
the address convereion table; 
Figure 6 shows showing an example of ttie con- 
struction of the block managing table; 
Figure 7A is a flowchart showing the normal proc- 
essing of the command processing section; 
Figure 7B is a flowchart showing the normal proc- 
essing of the command processing section; 
Figure 7C is a flowchart showing the normal 
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processing of the command processing section; 
Figure 8 Is a flowchart showing the interruption 
processing of the command processing section; 
Figure 9A is a flowchart showing the process of 
initializing the managing table and conversion ta- 5 
ble in Figure 7A; 

Figure 9B Is a flowchart showing the process of 
initializing the managing table and conversion ta- 
ble in Figure 7A; 

Figure 1 0 is a flowchart showing the detail of the to 
file recovery processing in Figure 7A; 
Figure 11 is a flowchart showing the detaB of the 
sector read processing in Figure 8; 
Figure 12 is a representation explaining the sec- 
tor write processing; is 
Figure 13Ais a flowchart showing the detail of the 
sector write processing in Figure 7A; 
Figure 1 3B is a flowchart showing the detail of the 
sector write processing in Figure 7A; 
Figure 1 3C is a flowchart showing the detail of the 20 
sec^CM* write processing in Figure 7A; 
Figure 14 Is a representation explaining the sec- 
tor erase processing in Figure 7A; 
Figure 15 Is a flowchart showing the detail of the 
sector erase processing in Figure 7A; 25 
Figure 16 is a flowchart showing the detail of the 
compare processing of i and ie in Figure 15; 
Figure 1 7 Is a flow chart showing the detail of the 
blocic erase determination and start in Figure 15; 
Figure 18 shows an explanatory view of an exanv 30 
pie of sector erasing by comparison of the file lo- 
cation Information; 

Figure 1 9 is a flowchart showing the details of the 
sector erasing of Figure 18; 

Figure 20 is a time chart diagram showing the re- 3S 
lationship between the normal processing of the 
command processing section in Figure 2 and the 
interruption processing of CPU; 
Figure 21 shows an example of the computer sys- 
tem In which the semiconductor external storage 40 
system according to another embodiment of the 
present invention is incorporated; 
Figure 22 shows an example of the computer sys- 
tem in which the external storage system accord- 
ing to stlD another embodiment of the present In- 45 
ventlon is shown; 

Figure 23 is a flowchart showing part of the nor- 
mal processing of the command processing sec- 
tion in Figure 22; 

Figure 24 is a flowchart showing the processings so 
of the sector erase determination and start In Fig- 
ure 22; 

Figure 25 is a time chart diagram showing the re- 
lationship between the normal processing of the 
command processing section and the Interrup- 55 
tion processing of the CPU in Figure 22. 
Figure 1 shows an example of the computer sys- 
tem In which the semiconductor external storage sys- 



tem of the present invention is incorporated; CPU 10 
communicates via system bus 13 with main memory 
15, bus control unit 16 and coprocessor 14 for arith- 
metic operations which is optional. The communica- 
tions between CPU 10 and its associated peripheral 
devices are done via bus control unit 16. For this, bus 
control unit 16 is connected to the peripheral devices 
via family bus 18. As the peripheral devices, external 
storage system 20 made of a flash memory which Is 
an embodiment of the present Invention is connected, 
and communication device 21 . hard file 22 and optical 
disic 23 are also connected to family bus 18. 24 is a 
display controller and 25 is a CRT. Of course other 
peripheral devices can be connected. Such a comput- 
er system can be built from, for Instance, an IBM PS/2 
personal computer (IBM and PS/2 are trademarlcs of 
International Business Machines Corporation). 

Direct menrory access control unit (DMAC) 12 is 
provided to enable memory accesses by all or select- 
ed peripheral devices. For this, at least part of family 
bus 18 is multipoint-connected to DMAC 12. Although 
not shown in the figure, an arbitration circuit Is provid- 
ed in each peripheral device to which the DMA access 
Is allowed, and assigned an arbitration level (priority). 
On the DMAC 12 side, central arbitration control cir- 
cuit 11 is provided which performs arbitration work 
between a plurality of peripheral devices demanding 
a DMA access at the same time and notifies DMAC 
12 of which peripheral device has been allowed a 
DMA access. For details of tiie DMA control by DMAC 
12 and central arbitration control circuit 11, reference 
Is made to the US Patent No. 4,901,234. 

Figure 2 shows details of tfie functional structure 
of semiconductor external storage system 20. This 
semiconductor external storage system includes con- 
trol unit 30 connected to famSy bus 18, and flash 
memory 32 connected to semiconductor memory bus 
31. Control unit 30 Includes command processing 
section 34, block managing table 35, address conver- 
8k)n table 36 and buffer 37 which are Interconnected 
by control unit bus 33. Flash memory 32 consists of 
a plurality of memory blocks 320 (321-321) each con- 
taining a plurality of sectora. In this embodiment, as 
memory block 320, a flash memory chip is assumed 
which allows only a change from 1 to 0 and is all set 
to 1 by block erasure, but of course it should be noted 
that a chip could be used which is opposite to those. 
Command processing section 34 includes an arbitra- 
tion circuit and performs a DMA transfer and I/O con- 
trol. Address convereion table 36 is to convert the log- 
ical address sent form CPU 10 tiirough family bus 18 
to ttie physical address of flash nrienfK)ry 32, and con- 
sists of a random access memory. This random ac- 
cess memory can include buffer 37. 

Bus control section 38 has a well-known receiv- 
er/driver used for interconnecting semiconductor 
memory bus 31 and control unit bus 33. Although bus 
control section 38 is constructed so as to accomplish 
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parallel transfer of 16 bits between buses 31 and 33 
in this embodiment, the present invention of course is 
not limited to such parallel transfer. Command proc- 
essing section 34 manages data reading section 40. 
data wdting section 41 , copying section 42 and block s 
erasing section 43. 

Flash memory 32 is managed as a collection of 
sectors. In this embodiment, individual memory 
blocks 320 constituting flash memory 32 consist of 
512 sectors, and each sector includes 512 bytes. The io 
numbers of sectors and bytes may be changed de- 
pending on the storage capacity of memory block 320 
and the architecture. 

It should be noted that the term menrK)ry block as 
used herein means a region on the memory chip is 
which can be collectively erased by tiie block erasing 
section. Although one memory block corresponds to 
one memory chip in this embodiment, a plurality of 
memory blocks could exist in one memory chip, and 
one sector could correspond to one memory block as 20 
in the example of the sector erase type memory de- 
scribed later. 

Figure 3 shows the hardware arrangement of 
semiconductor external storage system 20 of Figure 
2. In the figure, ttie respective functional portions of 25 
command processing section 34, data reading sec- 
tion 40, data writing section 41, copying section 42 
and erasing section 43 are built with a microprocessor 
50. The micro code oonlroiling the microprocessor 50 
is stored in ROM 52. Since block managing table 35 30 
and address conversion table 36 are often modified 
and very fast access is required, they are formed on 
RAM 54. Microprocessor 50 communicates with the 
host CPU 10 via I/O register 56 at any time. Data 
transfer control unit 58 connects I/O bus 1 8 and local ss 
bus 33 as needed, thereby enabling data transfer be- 
tween buffer 37 and flash memory (EEPROM) 32. Ex- 
cept for data transfer, these buses are disconnected 
and microprocessor 50 can function independentty of 
host CPU 10. 40 

As shown in Figure 4, tiie first several sectors of 
each memory block 320 are used as sector managing 
table 60, in which the status 64 and logical address L 
66 of each sector are stored. The remaining sectors 
of each memory block 320 are used as data region 70 4S 
(70A>70N). The size of sector managing table 60 de- . 
pends on the memory block and the capacity of the 
sector included therein, and In the above described 
example of 512 sectors per blodc and 512 bytes per 
sector, four sectors are required as the sector manag- so 
ing table. To each sector 70A-70N, a logical address 
is assigned as described later. These sectors includ- 
ing sector managing table 60 are formatted on a mem- 
ory chip using a format program. 

Sector managing table 60 includes a plurality of 55 
entries each of four bytes, and in ttie first entry there- 
of, the number of times 62 ttie related memory block 
40 was erased is stored. In the second entry, status 



64 and logical address 66 of the first sector (in ttiis 
case, sector 4) used as data region 70A in the related 
memory block are stored. In tiie third entry, status 64 
and logical address 66 of the next sector 70B or sector 
5 are stored, and similarly, the status and togical ad- 
dresses of ttie subsequent respective sectors are se- 
quentially stored. 

Status 64 of a sector Is indicated by a 4-bit status 
flag as described below. Since the status flag is on the 
flash memory, the bit change is limited in one direc- 
tion. 

1111 = blank 

1110 « valid 

1100 = invalid 

00(M) = under erasure 
The status for each memory block is recorded in block 
managing table 35 on the basis of status 64 In sector 
managing table 60. Figure 6 shows an example of 
block managing table 35. in which the number of blank 
sectors B (i, 1) 72 and the number of valid sectors B 
(i, 2) 74 per memory block i, and the number of blank 
sectors B (. 1) 76 of the whole memory block are re- 
corded. 

Returning to Figures 2 and 3, command process- 
ing section 34 communicates with CPU 37 via buffer 
37. That is, the CPU command and data are DMA- 
transferred to buffer 37 under control of DMAC 12, 
and command processing section 34 fetches the com- 
mand firom buffer 37 and executes it. Since flash 
memory 32 is seen from CPU 10 as if it were a hard 
disk or floppy disk, the command transferred to buffer 
37 Is the same type as the command for such disk and 
contains sector address L in addition to the OP code. 
In external storage system 20, the sector address L 
is treated as logical address 66. Address conversion 
table 36 which provides ttie relationship between the 
sectoraddressL(loglcal address 66) and physical ad- 
dress A (L) (pointer 68) of memory block 40 is held on 
RAM 54 with tiie construction as shown in Figure 5. 

Now, the operation of control unit 30 of external 
storage system 20 will be described. Command proc- 
essing section 34 usually independentty executes 
processes such as sector writing and block erasing. 
It receives the command and data from host CPU 10 
by interruption. The normal processing is ouflined in 
Figures 7-8. 

First, in ttie f iret step of Figure 7 (Figure 7A - 7C), 
the initialization of the block managing table and ad- 
dress conversion table is done (702). Then, it is de- 
termined whether or not file recovery Is required for 
disconnection of the power supply or the like, and the 
process therefore is executed if necessary (704, 
706). Next, it Is checked whether ttiere \s any com- 
mand sent from host CPU 10 to buffer 37 (708). If 
there Is a write command, the existence of blank sec- 
tore in memory block 40 is checked (total number B 
(, 1) > 0), and a writing is performed if there is a blank 
sector (710 - 714). If it is a sector erase command, the 
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erasing process of the corresponding sector is done 
(716, 718). if a certain memory block is determined 
to be a memory block ie to be erased, the block eras- 
ing process (later described in detail) is started. In the 
block erasing process, the sector copy to other menv 
ory blocks is undertaken to save valid sectors as de- 
scribed later. When the sector copy is terminated, the 
command processing section holds the number of 
times the memory block was erased and thereafter 
commands block erasing section 43 to execute block 
erasing of the correspond- Ing mentory block Ie (720 
- 724). The number of erasing times is stored and 
managed in the first four bytes of the sector managing 
table, and it is Incremented by one after completion of 
the erasure and written back (728). Then, the erased 
block ie is made to be blank block ib (730), the records 
of the sector managing table and block managing ta- 
ble 35 are updated. That is, the number B (i, 1) of em|>- 
ty sectors In the memory block i is made to be M and 
the number B (i, 2) of effective sectors is made to be 
0 (732, 734). 

However, If the number of erasing times of a cer- 
tain memory block i to be collectively erased is small- 
er than that of a memory block ie, an erase candidate, 
by a certain value, the memory block i is selected as 
the ntemory block ie which is the erase candidate 
used to make uniform the number of erasing tftnes, re- 
gardless of whether the number of the "valid" sectors 
is large or small (736). If there Is no further memory 
block ie to be erased in all the memory blocks and no 
blank sector Iw exists, the request for memory re- 
placement Is displayed on CRT 25 (Figure 1) (738, 
740). This display may be done earlier so as to leave 
time to spare. 

The request for processing from host CPU 10 to 
external storage system 20 Is accepted by the previ- 
ously mentioned interruption in the normal process- 
ing. As shown in Figure 8, when command processing 
section 34 accepte a command from host CPU 10 
(802), it executes the processing required for a sector 
reading (804, 806), a sector writing (808, 810) or sec- 
tor erasing (812, 814). To execute each command, 
command processing section 34 looks up address 
conversion teble 36 for the logical (sector) address 66 
in the command and obtains the corresponding phys- 
ical address 68. The physical address 68 consiste of 
a blocks address (i) specifying a particular memory 
btock 32i of flash menrwry 32, and a sector address 
(j) specifying a particularsector j in that block. 

The deteils of each processing of the command 
processing section 34 will now be described. First, tiie 
initialization of the block managing table and address 
conversion table (Figure 7A, step 702) is described. 
Figure 9 (Figures 9A, 9B) shows the details of tiie Ini- 
tialization process of the block managing teble and 55 
address conversion teble. The block number 1 and 
sector number j are initialized, the number of empty 
sectors B (i, 1) and the number of valide sectors B (i, 



2) are both set to zero (902, 904), and the status of 
the j-tii sector in block i and date S (i, J) of pointer L 
are obtained from sector managing teble 60 (906). ff 
the sector is vacant add one to the number of blank 
sectcMTs B (i. 1) in block 1. If the sector Is not vacant, 
then tiie sector is checked for validity, and If it Is valid, 
physical address 68 is stored in L-th A (L) of address 
converston teble 36 (914) and one Is added to the 
number of valid sectors B (i, 2) (916). A similar proc- 
essing Is executed until sector number j reaches tiie 
total number d sectore M in block 1 (920). Further, a 
similar processing Is repeated for all blocks N (922 - 
924). The number iw of the block in which a sector 
writing is performed, tiie number ie of the candidate 
btock for erasure, and the number ib of tiie blank block 
in which data is to be saved for the erasure are deter- 
mined (926). 

The file recovery (Figure 7A, step 706) is descri- 
bed below. In the conventional magnetic disk file, date 
is overwritten on the sector when the sector is rewrit- 
ten, and thus. If a power teilure occure in the course 
of rewriting a file for Instence, both old and new fSes 
would be lost On the other hand, in tiie present inven- 
tion, a new sector is found for the sector rewriting wlth< 
out overwriting the old sector, and thus the old date 
continues to be valid until the block including the date 
is erased (however, the stetus flag of the sector has 
already been rewritten to invalid). Accordingly, if a file 
writing has tailed, It is possible in nK>st cases to find 
old sector 66 from the value of L in S (i. j) and repro- 
duce the file regardless of stetus flag 64. 

Figure 10 shows details of the file recovery, ifthe 
power supply is disconnected during a file writing by 
and accident or tiie like, the date in buffer 37 or RAM 
54 is lost Then, the old file is recovered when the 
power is turned on again. First the directory informa- 
tion and file allocation Information are read out to ob- 
tein tiie leading sector number K of tiie file (1002, 
1004). As the sectors corresponding to the sector 
numbera written until the power was turned off, both 
Invalid sectors having old data and valid sectors hav- 
ing new date exist. Then, an invalid sector having the 
sector number K is searched, and if there is one pres- 
ent the date of the sector is moved to a new blank 
sector after obteining the user's confirmation to make 
It valid. The existing valid sector is made invalid 
(1010). The user's confirmation is obtelned because, 
ifthe bid data comprises plural verelons, confirmation 
is obtained as to which one should t>e selected. Asim- 
ilar processing is done for all the sectore constituting 
the file (1014). The old fOe Is reconstructed by gath- 
ering the data of invalkJ sectore in this way. 

Figure 11 Is a deteiled flow of the sector reading 
(step 806 of Figure 8), in which a physical address A 
(L) 68 corresponding to a given logical address L 66 
is obtelned from address converelon teble 36, the 
positions sectore 70A- 70N are found, and date (AL) 
is set In data reading section 40 and DMA-trensferred 
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to CPU 10. 

Now, the sector write processing (step 714 of Fig- 
ure 7A) is described. In Figures 2 and 12, command 
processing section 34 first obtains the logical address 
L given by host CPU 1 0 from buffer 37, and then loolcs 5 
up address conversion table 36 to obtain physical ad- 
dress A (L). Further, it traverses block managing table 
35 to find the position of the blank sector 70N in data 
region 70. And, it reads out the data received from 
host CPU 1 0 from buffer 37, writes this new data into io 
the blank sector 70N, and rewrites its status flag 64N 
from "blank" to "Valki" and the status flag 64Aof the 
old sector 70Afrom "valid" to "invalid." Then, it stores 
the coriBSpondence between the logical address 66 
and the physical address of the new sector 70N spe- is 
cif led by host CPU 10 in address conversion table 36, 
and the record of the block managing table is renewed 
as to the number of blank sectors (i, 1 ), the number of 
valkl sectors (i, 2) and the total number of empty sec- 
tors B (, 1 ). InckJentally, the memory block iw contain- 20 
ing the new sector 70N may exist in the same memory 
block 320 as the old sector 70A or in another memory 
block. 

Figure 13 (13A- 13C) shows details of the above 
sector write processing. 25 

First, the logical address L included in the com- 
mand given firom host CPU 10 is obtained (1302). 
And, if the processing of the later described file allo- 
cation information is required, that processing Is done 
(1304, 1306) and then the physical address A (L) is so 
pbteined from address converston table 36 (1308). 
Further, the old memory number i and sector mumber 
j are obtained for the A (L) (1314). Then, the memory 
address P of the blank sector in the memory block iw 
in which the writing is done is obteined. and this P is 36 
set in date writing section 41 and the sector date is 
written (1316 - 1320). in addition, the sector number 
k of the writing destination is obtained from P, the date 
S (iw» k) of the pointer is made valid, L is stored, and 
P is made to be the physical address A (L) (1322 - 40 
1 326). Then, in order to logically erase the old date at 
the same logical address, the value S (i, J) of the old 
pointer L of the memory block is made invaikJ (1330) 
and the number of valid sectors B (i, 2) Is decreased 
by one (1 332). Moreover, it is determined whether or 4S 
not the block i is that to be erased next (1 334), and the 
number of blank sectors B (iw, 1) is reduced by one 
(1336). And, if the number of blank sectors becomes 
0, the nr^mory block having blank sectors is renewed 
as the memory block iw in which next writing is done so 
(1 340). However, the blank memory block selected as 
the copying memory block for saving the sector date 
is excluded. Finally, the determinatkm of the block 
erasing and the processing are done (1342). 

The procedure of sector erasing (step 71 8 of Fig- 55 
ure 7B) is now described in deteil according to Figures 
14-15. 

In Figure 1 5, each time the stetus flag of the sec- 



tors of a certein memory block 1 changes from "valid" 
to "invalid", command processing section 34 invali- 
dates the values S (i, J) of th pointer (1508) and dec- 
remente the number of "valid" sectors B (i, 2) in the 
memory block i in the block managing teble by one 
(1510). This logically erases the sector date, and 
physically holds it as it is valid. And, the physical ad- 
dress A (L) of the address conversion teble is made 
to be zero, and the number of the remaining "valid" 
sectors is compared with the erase candidate mem- 
ory block ie. If the number is smaller, this memory 
block 1 is selected as a candidate te of the memory 
block to be erased next (1514). 

In this embodiment, the number of "blank" sectors 
is always kept greater than a fixed value by the block 
erasing processing based on the block managing te- 
ble and sector managing teble. The "blank" sectors 
are used as destinations at which date is written or 
copied at the tbne of date writing or erasing. As shown 
In Figure 14. tfiero are many "empty" sectors initially 
existing in one memory block 321, but "valid" sectors 
and "invalid" sectors gradually increase. And, when 
the number of "valid" sectors 70 remaining in the 
memory block 321 becomes smaller than the prede- 
termined value, the "valkl" sectors 70 are copied into 
"empty" sectors in another memory block 322, and 
then the content of the memory block 321 is erased 
in bulk to make them all "blank" sectors. 

The command from CPU 10 is executed by inter- 
ruption even during the processing of copying sectors 
or erasing memory blocks. For instence, if the com- 
mand of CPU 10 is for date writing, a memory block 
323 other than the memory block 322 which is cur- 
rently copying date is selected, and a writing process 
is done In parallel with the copying. 
Consequentiy, the interrupt function (parallel proc- 
essing) is executed as long as blank sectors are se- 
cured, and thus Ute execution of the command from 
CPU 10 is not to wait 

Incidentelly, since it tekes time to copy the date 
of valid sectors prior to block erasure, tiie number of 
copying times is preferably as small as possible. Ac- 
cordingly, in step 1334 of Figure 13C and step 1514 
of Figure 15, a processing is done to minimize the 
number of valid sectors of the memory block to be 
erased, thereby suppressing the amount of copying to 
a small value. For this, if a certein sector now be- 
comes invalM, tiie number of valid sectors of the 
memory block i including that sector is compared with 
the number of valid sectors of the erasing candidate 
memory block Ie to determine the next erasing can- 
didate. The deteils of this are shown in Figure 16. 
First, the number of erasing times E (i) of a memory 
btock 1 in which a sector has now become invalid is 
compared with ttie upper allowance value X of the 
number of erasing times of that memory. This upper 
limit value X is set to. for instence, 10.000 times or 
100,000 times depending on the specification of the 
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memory block. If X is exceeded or there are blank sec- 
tors B (i, D in the memory block i. it is not necessary 
to change the erasing candidate and the determina- 
tion terminates (1602. 1610). If E (i) has not yet 
reached the upper limit X, then it is checked whether 5 
or not the difference between the memory block hav- 
ing the largest number of erasing times Q among the 
all memory blocks and the number of erasing times E 
(ie) of the erasing candidate memory block le is equal 
to or smaller than the maximum allowed value R for io 
deviatton of the number of erasing tinies (1604). R, an 
appropriate value between 100-1000 is selected for 
instance. If the deviation Is larger than R, the exam- 
ination of the memory block I is not required and the 
determination terminates. If, conversely, it is smaller is 
than R, comparison of the number of valid sectors B 
(1, 2) is done (1 606). If the memory block I has only val- 
id sectors B (1,2) less than the erasing candidate 
memory block ie. the memory block I Is newly re- 
placed as the next erasing candidate memory block 20 
ie (1608). InckJentally, since the total number of sec- 
tors in the memory block i Is known, it will be under- 
stood that the comparison of i and le may be done by 
the number of invalid sectors instead of the number of 
valid sectors. Referring to Figure 1 7, the detail of the 25 
determination processing, of block erasing (step 1342 
of Figure 13 C and step 1516 of Figure 15) Is descri- 
bed. First, the number of valid sectors B (ie, 2) of the 
erasing candkiate memory block ie is compared with 
a predetermined value S (1 702), and If the number of so 
valid sectors becomes smaller, sector copying section 
42 is instructed to copy and save the valid sectors in 
the block ie to the memory block ib for copying (1 706). 
The next writing or copying processing Is hindered If 
the number of the blank sectors In all the memory 35 
blocks Is small though there are nnany valkl sectors. 
Thus, if the total number of blank sectors B(, 1) is 
snnaller than a predetermined value T, sector copying 
processing is similarly performed for erasing (1704, 
1706). 40 

To efficiently reproduce blank sectors, it is need- 
ed to know the sectors erased by the host CPU as ear- 
ly as possible. However, the conventtonal file system 
only updates the file allocatk)n information when a file 
is erased by CPU 10, and it does not inform the ex- 4S 
ternal storage of which sectors were erased. In accor- 
dance with the embodiment of the present Invention, 
when the file system was rewritten (step 1304 of Fig- 
ure 13A), this problem can be solved by comparing 
the file allocation information as shown in Figs. 18 so 
and 19 without rewriting the file system. That Is, com- 
mand processing section 34 has a functton which 
compares the new and old file allocation information 
FAT. For this, the file allocation information Is utilized 
for which CPU 10 manages the logical address L. 55 
When the file system Is rewritten by CPU 10, that In- 
formation is stored at a specific logical address L by 
the operating system OS. Then, the old file allocation 



information FATO on the external storage side Is read 
out (1 902) and compared with each entry U of the new 
file allocation informatfon FATN at the CPU 10 side 
(1908), and if there is a sector 70N which was newly 
freed, sector erasing processing of the sector 70N Is 
dpne (1 912). A similar processing is performed for all 
entries to update the sector atetus on the external 
storage side. 

In accordance with the at>ove described embodi- 
ment of the present Invention, all the sectors are sut>- 
stantially uniformly used and a high-speed sector 
writing is enabled. Figure 20 shows a comparison of 
the processing times for sector writing in the conven- 
tional scheme (A) and the scheme of the present in- 
vention (B). In the cohventionat scheme, a block Is 
erased after all the date in the block are saved in the 
main memory or buffer at the beginning, and there- 
after the date are vnltten back to the memory block 
afong with the newly updated data. Usually there are 
about 64-256 sectors in a block, and it takes a con- 
sMerable amount of time to read out and write back 
all of them. The processing in the host CPU is inter- 
rupted during that time. On the other hand, in the 
scheme of the present inventton (B), as the process- 
ing by CPU 10 for sector writing, it is only needed to 
write one sector, which eliminates the need for the 
data saving processing that has conventfonally been 
required, and the block erasing is independently exe- 
cuted in command processing section 34 in parallel 
with the (other) processing of CPU 10. Accordingly, a 
fairly high speed sector writing as compared with the 
conventional scheme. In other words, the shortening 
of the binding time of CPU 10 is allowed. The reason 
for this is that the present inventfon manages memory 
btocks and sectora so as to always separately prepare 
a memory block In which sectors are written a mem- 
ory block to be erased and a blank memory block. 
This allows the parallel executfon of a sector writing 
and a memory block erasing, and a sector writing and 
a memory block erasing. 

Figure 21 shows another embodiment of the pres- 
ent Invention, which Is different In that command proc- 
essing function 34 Is provided by host CPU 10, as 
compared with the example of Figure 2. Also, block 
managing table 35 and address conversion table 36 
are located on main memory 15 (Including a buffer) 
and referenced by the host CPU. Host CPU 10 sends 
an Instruction to memory controller 80 via I/O bus 18 
for a sector reading or writing. The memory controller 
is formed as an Integrated circuit on a silicon sub- 
strate which is separate from the host CPU, and pro- 
vkles thefunctbns of data reading 40, data writing 41, 
sector copying 42and block erasing in addition to buf- 
fer 37. Memory controller 80 can access to flash 
ntemory 32 independently of host CPU 10, and notify 
the host CPU of ttie end of a task via I/O bus 1 8. Since 
the other operations are the same as the embodiment 
of Figure 2. the explanation thereof is omitted. 
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Further. Figure 22 shows another embodiment of 
the present invention which uses a sector erase type 
flash memory as memory block 32. The sector erase 
type is a type in which the size of a memory block 
erased in bulk is equal to the physical size of the f 8e s 
sector. Since the erasing is performed for each sector 
in this example, the sector saving prior to block era- 
sure is not necessary as compared with the example 
of Figure 2, and accordingly there is no sector copying 
section 42, and instead of block erasing section 43, io 
sector erasing section 82 is formed on a microproces- 
sor to perform the saving and recovery of the number 
of erasing times of sectors. In addition, sector manag- 
ing table 60 Is provided for each unit of memory block 
320, or sector 70. The status and the number of eas- 15 
ing times of sectors are recorded In sector managing 
table 60, and empty sectors for writing are secured in 
consideration of the number of erasing times of all the 
sectors. The normal processing of the conrunand 
processing section is used to check the buffer, and if 20 
there Is a command, executes a sector writing or eras- 
ing as shown in Figure 7. However, as shown in Figure 
23, the processing performing a sector copying prior 
to a sector erasing is unnecessary, and the erasing of 
invalid sectors is immediately executed (727-733). 25 
Further, as shown in Figure 24. processing te required 
to save the number of erasing times of a sector prior 
to the erasing of the sector and for writing it back 
(1705-1707). 

Also in this embodiment, as shown in Figure 25, 30 
ail sectors are almost evenly used and high-speed 
sector writing Is enabled. In this example, since the 
erasing is done on a sector basis, the saving of data 
and the copying of sectors are not necessary. In the 
conventional scheme (A), the host CPU also needs to 35 
do the erasing of a sector each time ttie sector te writ- 
ten. In the scheme of tiie present Invention (B), ttie 
processing of the host CPU is only used to write a sec- 
tor and ti^ie otfier processings, for instance, sector 
erasing is independentiy processed by ttie memory 40 
controller, and thus the processing time of the host 
CPU may be short and a high-speed sector writing is 
made possible. 

Incidentally, if the semiconductor has a large ca- 
pacity, the semiconductor menrwry may be divided 4S 
into a plurality of groups each having a plurality of 
memory blocks, and the above described nrmnaging 
and control of blocks and sectors may be performed 
for each group. 

In accordance with the present invention, a senrv- so 
iconductor external storage system using a flash 
memory is used which can process data reading and 
writing at high speed in response to the command of 
the host CPU. In addition, an external storage system 
is obtained in which, even if the command of ttie host 55 
CPU firequentiy rewrites a particular sector of the 
flash memory, the number of erasing times of sectors 
are not biased on the actual flash memory and the 



whole can be effectively utilized. 

In a computer system comprising a host proces- 
sor, a semiconductor memory Is used as an external 
storage device consisting of a flash memory and 
comprised of a plurality of memory blocks each in- 
cluding at least one sector, and a control section per- 
forming control over said memory blocks, a method 
has been described for controlling ttie external stor- 
age devk:e of a computer system wherein said control 
section converts the logical address included in the 
command of said host processor to a physical ad- 
dress Indicating the sector in a particular memory 
block by address conversion means, selects a mem- 
ory block for data writing and a memory block for era- 
sure to be erased next to acquire sakl memory block 
for data writing, respectively, on the basis of tiie re- 
cord of block managing means which has sequentially 
recorded therein the number of times each memory 
block was erased and the stotus of each sector and 
memory block, writes the data to be written received 
from said host processor into said memory block for 
writing, and erases said selected memory block for 
erasure. 

To provide an external storage system using a 
semiconductor memory in which the date reading and 
writing between the host CPU can be processed fast- 
er than the conventional magnetic disk, and only a 
particular sector is not frequentfy written and erased 
so that the whole memory is effectively used over a 
long period of time. An address control scheme was 
introduced In which flexibility Is given to the address 
relation between the host CPU and the external stor- 
age and the physical address of the semiconductor 
memory is not one-sidedly determined by ttie logical 
address possessed by ttie command of ttie host CPU. 
Command processing section 34 always prepares 
memory blocks and sectore for writing or erasing and 
copying in preparation for ttie command processing of 
the host CPUt and records and holds the correspon- 
dence relation between the physical address of the 
selected memory block 32i or sector and the conv 
mand of the host CPU in address conversion table 36. 
The stetus of memory blocks and sectors is recorded 
in respective managing tebles 35 and 60, and used for 
control of processings such as writing, erasing and 
copying in preparation for or in response to the com- 
mand of the host CPU. 



Claims 

1. A method for controlling a storage system com- 
prising a semiconductor memory of the flash 
memory type, the mennory comprising a plurality 
of memory blocks each including atleastone sec- 
tor, and a control device for controlling said menv 
ory blocks, said storage system being connected 
to a host processor through a bus for transferring 
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data and a command, the metpd comprising; 

selecting a memory block for wtilch data is 
to be written or erased on the basis of a memory 
managing table which has recorded therein the 
number of times each memory block was erased 
and the statuses of each memory block and each 
sector; 

converting the logical address Included In 
said command of said host processor to a physi- 
cal address Indicating the sector in a particular 
memory block by reference to an address conver- 
sion table; 

responding to said command to perform a 
process of data writing or reading to the corre- 
sponding sector or memory block erasure; 

sequentially recording or updating in said 
memory managing table the status changes of 
each sector and menfK>ry block resulting from the 
processes; and 

storing or updating in the address conver- 
sion table the relationships between the physical 
addresses and the logrcal addresses of the mem- 
ory block and sector on which saki processes 
were performed. 

2. A method as claimed in Claim 1 comprising ac- 
cepting the command of said host processor by 
interruption, and If said command is a data read 
command, responding thereto to perform the 
process of reading the data from the correspond- 
ing sector of said memory block corresponding to 
the logical address of said command, and If said 
command is a write or erase command, holding 
such command and data in a buffer and execut- 
ing said write or erase process to sakl selected 
memory block or sector when there Is no Interrupt 
command from said host processor. 

3. A method as claimed in Claim 1 or Claim 2, com- 
prising selecting a particular memory block of 
saki memory blocks with priority as an object to 
be erased if the number of times said particular 
memory block was erased Is smaller than the 
largest number of times any other memory block 
was erased by a predetermined value. 

4. A method as claimed In any of Claims 1 to 3 conr>- 
prising selecting based on the record of said block 
control means, a memory block having free sec- 
tors for copying the data in the valid sectors of 
saki memory block to be erased, and 

copying said data into said selected menv 
ory block prior to the erasure of said memory 
block. 

5. A method as claimed in any preceding claim conn- 
prising executing the process of reading the data 
from a corresponding sector of said memory 



block and said write or erase process to said 
memory block or sector by a time sharing proc- 
ess. 

5 6. A method as claimed in Claim 5 comprising re- 
sponding to a sector write command from said 
host processor by writing said data into a free sec- 
tor of said selected memory block, and if the log- 
ical address of said sector write command is 

10 equal to the logical address of the valid sector 
which has already been written, rewriting tiie re- 
cord of the status with respect to said valid sector 
of the nnemory management table to be invalid, 
and writing the physical address of saM free seo- 

15 tor into said address translation tabllB. 

7. A method as claimed in any preceding daim conn- 
prising saving the record of ttie number of times 
a ntemory block has been erased prior to each 

20 erasure of sakJ memory block, and writing said re- 
cord back to said memory block after erasure of 
said memory block. 

8. Amethod as claimed In any preceding daim conv 
25 prising updating tiie record of said memory man- 
agement table on the erasure of a memory block 
by comparison of the new file allocation informa- 
tion held by said host processor with the old file 
allocatk)n information held in the external storage 

30 system. 

0. An external storage system connected to a host 
processor through a host bus for transferring data 
and a command comprising: 
35 a semiconductor memory consisting of a 

flash memory and comprised of a plurality of 
memory blocks each induding at least one sec- 
tor, 

address oonverston means for converting 
40 the logical address received from said host proc- 
essor to the physical address of a particular sec- 
tor. 

block managirig means for recording the 
status of each memory block and sector, and 
45 a command processing section which 

uses the record of sakJ block managing means to 
control the reading or writing of data to each sec- 
tor of sakJ semteonductor memory, or the erasing 
of a memory block. 

50 

10. An external storage system as daimed in Claim 
9 wherein said control section includes a data 
writing section, data reading section and block 
erasing section for executing a data writing, rcfad- 
05 ing or erasing process to the corresponding 
memory block or sector of said semiconductor 
memory on the basis of said command process- 
ing section, and a sector copying section for copy- 
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Ing the valid sectors of the memory block to be 
erased to another memory block. 

11. An external storage system as claimed In Claim 

9 wherein said control section includes: 5 

a command processing section, data writ- 
ing section, data reading section, block erasing 
sectton, and a sector copying section used for 
copying the valid sectors of a memory block to be 
erased to another memory block which consists 10 
of a microprocessor, a block managing table, ad- 
dress conversion table and a buffer which are 
formed on RAM, and 

a sector managing table constituting said 
block managing means along with said block is 
managing table provided on each memory block. 

12. An external storage system as claimed in Claim 
9 wherein said control section includes: 

a command processing sectton fornfied on 20 
a host processor, 

a block managing table and an address 
conversion table formed on the RAM of the main 
memory, 

a memory controller including a buffer, 25 

and 

a sector managing table constituting said 
block managing means along with said block 
managing table provided on each n>emory block. 

30 

13. A computer system comprising a host processor, 
an external storage system Including a semicon- 
ductor memory which consists of a flash memory 
and comprises a plurality of memory blocks each 
including at least one sector, and a host bus for 35 
transferring data and a command between said 
external storage system and said host processor, 
characterized by: 

control means which uses an address con- 
version means for converting the address from 40 
said host processor to the physical address of a 
particular sector and block managing means for 
recording the status of each memory btock and 
each sector therein to control the data reading 
and writing to each sector of said semiconductor 4S 
memory and the erasure of a memory block in re- 
sponse to said command, 

sakJ control means having means which 
are responsive to the command firom said host 
processor for executing the process of data writ- so 
ing or reading to the corresponding sector of saki 
semiconductor menrK)ry or of erasing a memory 
block, and for updating the record of the status of 
each memory block and each sector of said block 
managing means in oonnectfon with such proc- 55 
ess. 

14. Acomputer system as claimed in Claim 13 having 

11 



display means connected to the host processor 
and the external storage system through the host 
bus, wherein 

said control means outputs to said display 
means that said semiconductor memory is to be 
replaced when there is no free sector in any of 
said memory blocks and there is also no memory 
block to be erased. 

1 5. A computer system as claimed in daim 1 3 having 
interactive display means connected to the host 
processor and the external storage system 
through the host bus, wherein 

said control means receives information 
as .to whether or not file recovery Is required from 
a user by an interaction via said display means, 
and if file recovery is required, refers to the file al- 
locatton information held by the computer system 
and displays the content of the file, and obtains 
the user's confirmation, thereby performing the 
file recovery. 

16. A semiconductor memory consisting of a flash 
memory and comprising a plurality of memory 
blocks each including at least one sector, wherein 

a particular region is provided in each said 
memory block for storing the record representing 
the number of times said memory block was 
erased and status of each sector. 

17. Asemiconductor memory as claimed in Claim 16 
wherein one said particular region is provided for 
each memory block as a sector managing table 
for recording the status of all the sectors induded 
in each memory block. 



EP 0 522 780 A2 



F IG. 1 



Processor 




10 



CPU 



DMAC 
12 



Central 
Arbi trat ion 
Circuit 
1 1 



18- 



16 



Bus Control 
Unit 



20 



.21 



Semiconductor 
External 
Storage 
System 



Conrmun Ication 
Unit 



Hard File 
V22 



13 



Optical Disk 

— ^ 



^25 



24 


< 








25 



12 



EP 0 522 780 A2 



F IG . 2 





^55 


^16 


Command 




Block 




Address 


Data 




Managing 




Conversion 


Buffer 




Table 




Table 



7\ 



Host 
CPU 



18- 



Address/Data 



I /O Bus 



20 



33 





Conrynand 




Processing 




Section 



If 



Data 
Reading 
Sect ion 



.30 



34 



Data 
Wr i t ing 
Section 



Data 



Sector 
Copying 
Sect ion 



33 



Block 

Erasing 

Section 



Address/^Data 



V 



53 



32 i 



32 



38 



Bus 

Control 
Section 




I 



31 



Flash 
EEPROM 



Sector 

Managing Table 



13 



EP0S22 780 A2 



S2 



I/O Bus 




I/O 
Register 



1 



20 p£ 



z. 



Data Transfer 
Control 



1 



Flash 
E EPROM 



Sector 

Managing Table 



58 



Micro 
Processor 



ROM 



Command 
Processinc 


— J4 


1 1 




Data Reading 


-40 


1 1 




Data Writing 


— 41 






Sector Copying 


—42 






8locl< Erasing 


—43 











SO 



52 



S3 



RAM 



Block 
Managing Table 



Address 

Conversion Table 



36 



Buffer ^57 



54 



30 



14 



EP0522780A2 



F I G . 4 







320 


S(0, 


0) 


s<o, 1) 




















.... ., 


























Number of 
Erasing Times 


Status 


L 












































Sector 4 
70A 












Sectors 

70B I 


70 < 


1 



















15 



EP0«2 780 A2 



F IG.5 



^66 ^66 



L 


A( L) 


1 


1st pointer 


2 


2nd pointer. 


5 


Srd pointer 


• 
• 


• 
• 


• 
• 


♦ 
• 


N 


N- th pointer 



F IG. 6 



S5 



72 



74 



i 


Number of 
Empty Sectors 


Number of 
Valid Sectors 


0 


B ( 0 . 1 ) 


B( 0 . 2 ) 


1 


B( 1 . 1 ) 


B ( 1 • 2 ) 


2 


B ( 2 . 1 ) 


B ( 2 , 2 ) 


• 
• 
• 
• 


• 
• 
• 
• 


• 
• 
• 
• 


N- 1 


B( N- 1 . 1 ) 


B ( N-1 , 2 ) 




B< . 1 ) 




16 


76 



EP 0 522 780 A2 



F IG. 7A 



( start > -7°° 



Ini t iai izat ion of 
managing table and 
conversion table (Figure 
9) 



6 



.702 



Fi le recovery 
(FigurelO) 




714 



2^ 



Yes 



Sector writing 
(FigureU) 



17 



EP 0 522 780 A2 



FIG.7B 



o 



No 




716 



■Rector erasingX ^ 
command ? 




Sector erasing 
( F igure 15 ) 



.718 



Save the number of 
erasing t imes of ie 







-.722 



I nstruct block 
erasing section to 
erase block Ie 



-724 




728 



Write back the 
number of erasing 
t imes of ie plus 1 



i b= i e 



.750 



,752 



B( i b , 1 )=M 



0 



18 



© 



EP 0 522 780 A2 



F IG. 7C 



0 



0 



B( ib,2)==0 






Determina 


t ion of le 



^722 



-756 




Yes 



No 



Exchange of flash 
EEPROM 



0 



.740 



& 



19 



EP 0 522 780 A2 



FIG. 8 



Start ) — 800 











Accepts command from 




host 




1 

1 







802 




data to buffer 



20 



EP0»2780 A2 



FIG.9A 



^ Start ^900 



I = 0 



j = 0 
B( I , 1 ) =0 
B( i , 2 )=0 



,902 



.904 



Obtain S(i , j> from 
sector managing 
table 



'906 




910 



B( i , 1 )«B( i , 1 )+1 



914 



Store the physical 
address in A (L) 



916- 



B( i ,2)=B( i ,2)+1 



d) 



21 



EP 0522 780 A2 




22 



FIG. 10 



EP0522780 A2 



1000 



Obtain fir 
number k f 
location i 


St sector 
rom it le 
nformat ion 






i = 


= K 






Search inv 
having sec 


al id sector 
tor No. i 



-1002 



'1004 



1006 




Replace se 
conf imriat i 


ctor user's 
on 






Obtain the next 
sector nunnber from 
file location 
information and make 
it i 



.1010 



-1012 



1016 




23 



EP0S22780 A2 



FIG.1 1 



Q start ^ — 1100 







Obtain logical address 
L given from host 






Obtain physical address 
ACL) from conversion 
table 






Set A (L) in data 
reading sect Ion 






Transfer sector data 







J 102 



-1 104 



-1 106 



-1 108 



10 



24 



EP 0 522 780 A2 



i 



FIG. 12 



.64A 



.66A 520 



|lliiP'!!!!| 




25 



EP 0 522 780 A2 



F IG. 1 5A 



1SQ0 



Obtain logical 
address L given 
host 



from 



'130 2 




No 



Connparison of file 
location information 
(Figure 19) 



'1506 



Obtain physical 
address A(L) from 
conversion table 



-1508 







i = 0 



J310 




Obtain block and 
sector numbers i 
and j 



-1514 



o 



26 



EP 0 522 780 A2 



F IG. 1 5B 



o 



Obtain memc 
of empty se 


>ry address p 
ctor in iw 






Set p in data wr i t ing 
section 






Write sector data 






Obtain sector No. k 
from p 






Make S (iw.k) valid and 
store L 






A( L 





1516 



-1518 



M520 



-1522 



1524 



.1526 



© 



27 



EP 0 522 780 A2 



F IG. 1 5C 




No 



In val Ida 


ite S(t , j) 






B( j ,2)=B( i ,2)-1 






Compare 
(F igure ' 


i and ie 
16) 



-1350 



-1352 



'1354 



B C i w , 1 ) = 
B( i w . 1 >- 1 



.1556 



1338 




Yes 



No 



Update iw wi th block 
having empty sectors 



'1340 



Determination of block 
erasing and start 



.1542 



-1544 



28 



EP0522 780A2 



F IG. 1 4 



521 



I nva I i d 




522 



m 



Empty 



Vat id 



Batch erasing 






^23 




n 


Writ 




ing 






Empty 



r 



29 



EP 0 522 780 A2 



F IG. 1 5 



1500 



Obtain given logical 
address L 



•1502 



Obtain physical 
address ACL) from 
conversion table 



'1504 



Obtain block and 
sector Nos. i and j 
frond ACL) 



1506 



.1508 



Inval idate S CI* j) 



BC i , 2) = 


BC i ,2 )-1 






ACL ) = 0 


t 



-1510 



.1512 



Compare i and ie 
CFigureU) 



, — 1514 



Determination of 
block erasing and 
start (Figure 17 ) 



-1516 



30 



\ 



EP0522780 A2 



F I G . 1 6 




31 



EP0S22780 A2 



FIG. 17 




F IG. 1 8 



F ATN 


1 


Compare 






32 



EP0522780 A2 



F I G . 1 9 



1900 







Read out old 
information 


f i ie location 



'1902 



j 

To U^904 




Compare the i-th entry In file 
location information 



-^1908 




33 



EP0S22780 A2 



♦-3 
XO 




to 

E c 

i!G.2 

P « 

O »- at 
OO. M 




34 



EP 0 522 780 A2 



F IG.21 



lipi! 



Host 
CPU 



Command Processing 4 




I/O bus 



Main memory (RAM) 



6 lock managing 
table 



Address conversion 
table 



-34 



(Buffer) 



32 



18 



80 



Memory control I er 



Data reading —40 



Data writing | — ^41 
.42 



Sector copying 



Block erasing 



Buffer 



•45 
L37 




Flash 
EEPROM 



Sector 

managing table 



.60 



35 



EP 0 522 780 A2 



FIG. 22 



iliili 







^56 


Command 




Block 




Address 


Data 




Managing 




Managing 


Buffer 




Table 




Table 



18 



Host CP 



< 



Address/Data 



I/O bus 



Conmand 
Processing 
Sect ion 



XL 



35 

34 30 



r - 



Data 



S3 





40 




41 




Data 




Data 




Sector 


Reading 




Writing 




Erasing 


Section 




Section 




Sect ion 



I Address/Data | 



Bus 

Control 
Section 



^38 



60. 
70- 

70' 







MM 


Ml ' 






1 1 1 




1 1 1 


J 1 





.82 



'520 



36 



EP0S22.780 A2 



F IG. 25 




EP0522780A2 



FIG. 24 



1700 








Yes 



Yes 



c 



y 


^1705 


Save the nuniber of erasing 
. times of invalid sectors in 
block ie 




r ^^1707 


Instruct sect 
section to er< 
sectors 


or erasing 
ase invalid 



End 



1708 



38 



EP0S22 780A2 




39 



